package com.guigu.guliware.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.guigu.guliware.entity.WmsWareSku;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * <p>
 * 商品库存 Mapper 接口
 * </p>
 *
 * @author 陈俊杰
 * @since 2024-08-24
 */
public interface WmsWareSkuMapper extends BaseMapper<WmsWareSku> {
    /**
     * 查询有库存的仓库id
     *
     * @param skuId 商品id
     * @return 仓库id集合
     */
    List<Long> selectListWareIdHasStock(@Param("skuId") Long skuId);

    /**
     * 锁库存
     *
     * @param skuId  商品id
     * @param wareId 仓库id
     * @param num    锁定数量
     * @return 影响行行数
     */
    Long lockSkuStock(@Param("skuId") Long skuId, @Param("wareId") Long wareId, @Param("num") Long num);

    /**
     * 解锁库存
     *
     * @param skuId  商品id
     * @param wareId 仓库id
     * @param num    解锁数量
     */
    void unlockStock(@Param("skuId") Long skuId, @Param("wareId") Long wareId, @Param("num") Long num);
}
